package com.action.utils;

import com.action.entity.Redpacket;
import com.tencent.tencentmap.mapsdk.maps.model.LatLng;

import java.math.BigDecimal;

public class LocationKit {

    private static double EARTH_RADIUS = 6378.137;

    /**
     * @param redpacket
     * @param MinLon    ：最新经度 MaxLon： 最大经度   MinLat：最新纬度
     *                  MaxLat：最大纬度    type：设置返回经度还是纬度
     * @return
     * @throws
     * @Title: randomLonLat
     * @Description: 在矩形内随机生成经纬度
     */
    public static LatLng randomLonLat(Redpacket redpacket, double MinLon, double MaxLon, double MinLat, double MaxLat) {
        System.out.println("MinLon:" + MinLon + "MaxLon:" + MaxLon + "MinLat:" + MinLat + "MaxLat:" + MaxLat);
        BigDecimal db = new BigDecimal(Math.random() * (MaxLon - MinLon) + MinLon);
        BigDecimal lon = db.setScale(6, BigDecimal.ROUND_HALF_UP);// 小数后6位
        db = new BigDecimal(Math.random() * (MaxLat - MinLat) + MinLat);
        BigDecimal lat = db.setScale(6, BigDecimal.ROUND_HALF_UP);
        System.out.println("randomLonLat:" + lat.doubleValue() + " lng:" + lon.doubleValue());
        redpacket.setLat(lat.doubleValue());
        redpacket.setLng(lon.doubleValue());
        return new LatLng(lat.doubleValue(), lon.doubleValue());
    }

    /**
     * 计算地球上任意两点(经纬度)距离
     *
     * @param long1 第一点经度
     * @param lat1  第一点纬度
     * @param long2 第二点经度
     * @param lat2  第二点纬度
     * @return 返回距离 单位：米
     */
    public static double distanceByLongNLat(double long1, double lat1, double long2, double lat2) {
        double a, b, R;
        R = 6378137;//地球半径
        lat1 = lat1 * Math.PI / 180.0;
        lat2 = lat2 * Math.PI / 180.0;
        a = lat1 - lat2;
        b = (long1 - long2) * Math.PI / 180.0;
        double d;
        double sa2, sb2;
        sa2 = Math.sin(a / 2.0);
        sb2 = Math.sin(b / 2.0);
        d = 2 * R * Math.asin(Math.sqrt(sa2 * sa2 + Math.cos(lat1) * Math.cos(lat2) * sb2 * sb2));
        return d;
    }

    /**
     * 根据经纬度和半径计算经纬度范围
     *
     * @param raidus 单位米
     * @return minLat, minLng, maxLat, maxLng
     */
    public static double[] getAround(double lat, double lon, int raidus) {

        Double latitude = lat;
        Double longitude = lon;

        Double degree = (24901 * 1609) / 360.0;
        double raidusMile = raidus;

        Double dpmLat = 1 / degree;
        Double radiusLat = dpmLat * raidusMile;
        Double minLat = latitude - radiusLat;
        Double maxLat = latitude + radiusLat;

        Double mpdLng = degree * Math.cos(latitude * (Math.PI / 180));
        Double dpmLng = 1 / mpdLng;
        Double radiusLng = dpmLng * raidusMile;
        Double minLng = longitude - radiusLng;
        Double maxLng = longitude + radiusLng;
        return new double[]{minLat, minLng, maxLat, maxLng};
    }
}